<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
      xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
    <meta charset="UTF-8">
    <title>公告管理</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta http-equiv="Access-Control-Allow-Origin" content="*">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="icon" href="/resources/favicon.ico">
    <!--<link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
    <link rel="stylesheet" href="/resources/layui/css/public.css" media="all" />-->
    <link rel="stylesheet" href="resources/layui/css/layui.css" th:href="@{/resources/layui/css/layui.css}"
          media="all"/>
    <link rel="stylesheet" href="resources/css/public.css" th:href="@{/resources/css/public.css}" media="all"/>
</head>
<body class="childrenBody">
<!--查询条件开始-->
<!--<fieldset class="layui-elem-field layui-field-title" style="margin-top: 10px;">
    <legend>查询条件</legend>
</fieldset>-->

<label class="layui-form-label">查询条件：</label>
<hr class="layui-bg-orange">
    <form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form">
        <div class="layui-form-item">
            <div class="layui-inline">
                <label class="layui-form-label">公告标题</label>
                <div class="layui-input-inline">
                    <input type="text" name="title" id="title" class="layui-input input-radius"
                           placeholder="请输入共告标题">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">操作人</label>
                <div class="layui-input-inline">
                    <input type="text" name="opername" id="opername" class="layui-input input-radius" placeholder="请输入操作人名称">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">开始时间</label>
                <div class="layui-input-inline">
                    <input type="text" name="startTime" id="startTime" readonly="readonly" placeholder="yyyy-MM-dd"
                           class="layui-input input-radius">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">结束时间</label>
                <div class="layui-input-inline">
                    <input type="text" name="endTime" id="endTime" readonly="readonly" placeholder="yyyy-MM-dd"
                           class="layui-input input-radius">
                </div>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;padding-right: 15%;">
                <button type="button" class="layui-btn layui-btn-sm layui-btn-radius" lay-submit="" lay-filter="doSearch"><i
                        class="layui-icon layui-icon-search layui-icon-normal"></i>查询
                </button>
                <button type="reset" class="layui-btn layui-btn-sm layui-btn-radius layui-btn-warm"><i
                        class="layui-icon layui-icon-refresh"></i><span>重置</span>
                </button>
            </div>
        </div>
    </form>


<!--查询条件结束-->

<!--数据表格开始-->
<div>
    <table class="layui-hide" id="noticeTable" lay-filter="noticeTable"></table>
    <div id="noticeToolBar" style="display: none;">
        <button type="button" lay-event="batchDelete" class="layui-btn layui-btn-sm layui-btn-danger layui-btn-radius">
            <span class="layui-icon layui-icon-delete"></span>批量删除</button>
        <button type="button" lay-event="add" shiro:hasPermission="notice:create" class="layui-btn layui-btn-sm layui-btn-normal layui-btn-radius">
            <span class="layui-icon layui-icon-add-1"></span>添加公告</button>
    </div>
    <div id="noticeRowBar" style="display: none;">
        <button type="button" lay-event="delete" shiro:hasPermission="notice:delete" class="layui-btn layui-btn-sm layui-btn-danger layui-btn-radius">
            <span class="layui-icon layui-icon-delete"></span>删除</button>
        <button type="button" lay-event="update" shiro:hasPermission="notice:update" class="layui-btn layui-btn-sm layui-btn-normal layui-btn-radius">
            <span class="layui-icon layui-icon-edit"></span>修改</button>
        <button type="button" lay-event="show" shiro:hasPermission="notice:viewnotice" class="layui-btn layui-btn-sm layui-btn-radius">
            <span class="layui-icon layui-icon-about"></span>查看</button>
    </div>
</div>

<!--数据表格结束-->

<!--添加和修改弹出层开始-->
<div id="addOrUpdateDiv" style="display: none;padding: 5px;margin-right: 4%">
    <form action="" method="post" class="layui-form" id="dataFrm" lay-filter="dataFrm">
        <div class="layui-form-item">
            <label class="layui-form-label">公告标题</label>
            <div class="layui-input-block">
                <input type="hidden" name="id">
                <input type="text" name="title" lay-verify="required" autocomplete="off" class="layui-input input-radius" placeholder="请输入公告标题">
            </div>
        </div>
        <div class="layui-form-item">
            <label class="layui-form-label">公告内容</label>
            <div class="layui-input-block">
                <textarea class="layui-textarea"  name="content" id="content" placeholder="请输入公告内容" lay-verify="required"></textarea>
            </div>
        </div>
        <div class="layui-form-item">
            <div class="layui-input-block" style="text-align: center;padding-right: 7%">
                <button type="button" class="layui-btn layui-btn-radius layui-btn-radius" lay-submit="" id="doSubmit">
                    <i class="layui-icon layui-icon-search layui-icon-ok"></i><span>提交</span>
                </button>
                <button type="reset" class="layui-btn layui-btn-radius layui-btn-warm layui-btn-radius">
                    <i class="layui-icon layui-icon-refresh"></i><span>重置</span>
                </button>
            </div>
        </div>
    </form>
</div>
<!--添加和修改弹出层结束-->

<!--查看公告弹出层-->
<div id="showNoticeDiv" style="display: none;padding: 10px">
    <h3 id="notice_title" style="text-align: center"></h3>
    <div style="text-align: right;margin-top: 2%">
        发布人：<span id="notice_opername"></span>
        发布时间：<span id="notice_createtime"></span>
    </div>
    <hr>
    <div id="notice_content"></div>
</div>


<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
    layui.use(['jquery','form','table','layer','laydate','layedit'],function(){
        var $=layui.jquery;
        var form=layui.form;
        var table=layui.table;
        var layer=layui.layer;
        var laydate=layui.laydate;
        var layedit=layui.layedit;
        laydate.render({
            elem:'#startTime',
            type:'datetime'
        });
        laydate.render({
            elem:'#endTime',
            type:'datetime'
        });

        //加载数据  render是渲染的意思
        var tableIns=table.render({
            elem: '#noticeTable'
            ,url:'/notice/loadAllNotice'
            ,toolbar: '#noticeToolBar' //开启头部工具栏，并为其绑定左侧模板
            ,title: '公告数据表'
            ,height:'full-230'
            ,page: true
            ,cols: [ [
                {type: 'checkbox', fixed: 'left'}
                ,{field:'id', title:'ID',width:80,align:'center'}
                ,{field:'title', title:'标题',width:220,align:'center'}
                ,{field:'opername', title:'发布人',width:130,align:'center'}
                ,{field:'createtime', title:'发布时间',width:250,align:'center'}
                ,{fixed: 'right', title:'操作', toolbar: '#noticeRowBar',align:'center'}
            ] ]

        });

        //初始化富文本编译器
        var editIndex = layedit.build('content',{
            tool: ['strong' //加粗
                ,'italic' //斜体
                ,'underline' //下划线
                ,'del' //删除线
                ,'|' //分割线
                ,'left' //左对齐
                ,'center' //居中对齐
                ,'right' //右对齐
                ,'link' //超链接
                ,'unlink' //清除链接
                ,'face' //表情
                ,'image' //插入图片
            ]
        });

        //打开添加的弹出层
        function openAddLayer() {
            mainIndex = layer.open({
                type:1,
                content:$("#addOrUpdateDiv"),
                area:['700px','500px'],
                title:'发布公告',
                success:function () {
                    $("#dataFrm")[0].reset();
                    //重置富文本编译器的内容为空
                    layedit.setContent(editIndex,"");
                    url="/notice/addNotice";
                }
            });
        }

        //添加和修改的提交
       /* form.on("submit(doSubmit)",function (data) {
            $.post(url,data,field,function (res) {
                if(res.code==200){
                    tableIns.reload();
                }
                layer.msg(res.msg);
            })
            return false;
        });*/

       //添加和修改的提交   弹出层的提交功能
        $("#doSubmit").click(function () {
            //alert(url);
            //同步富文本和textarea里面的内容
            layedit.sync(editIndex);
            var data = $("#dataFrm").serialize();   //获取dataFrm中数据
            $.post(url,data,function (res) {
                if (res.code==200){
                    tableIns.reload();
                }
                //提示操作是否成功，且关闭弹出层
                layer.msg(res.msg);
                layer.close(mainIndex);
            });
        });

        //打开查看的弹出层
        function showNotice(data) {
            mainIndex = layer.open({
                type:1,
                content:$("#showNoticeDiv"),
                area:['700px','500px'],
                title:'查看公告',
                success:function () {
                    $("#notice_title").html(data.title);
                    $("#notice_opername").html(data.opername);
                    $("#notice_createtime").html(data.createtime);
                    $("#notice_content").html(data.content);
                }
            });
        }


        //模糊查询
        form.on("submit(doSearch)",function (data) {
            tableIns.reload({
                where:data.field,
                page:{
                    curr:1
                }
            });
            return false;
        });

        //监控工具条事件     批量删除监听
        table.on("toolbar(noticeTable)", function (obj) {
            switch (obj.event) {
                case 'batchDelete':
                    batchDelete();
                    break;
                case 'add':
                    openAddLayer();
                    break;
            };
        });

        //监控行工具条事件      单个删除监听
        table.on("tool(noticeTable)",function (obj) {
            var data = obj.data;  //获取当前行数据
            switch (obj.event){
                case 'delete':
                    deleteNotice(data);
                    break;
                case 'update':
                    openupdateNoticeLayer(data);
                    break;
                case 'show':
                    showNotice(data);
                    break;
            };
        });

        //删除
        function deleteNotice(data) {
            layer.confirm('你确定要删除【'+data.title+'】这条公告吗？',{icon: 3,title:'提示'},function (index) {
                $.post("/notice/deletenotice",{id:data.id},function (res) {
                    if (res.code==200){
                        tableIns.reload({
                            where:"",
                        });
                    }
                    layer.msg(res.msg);
                });
                layer.close(index);
            });
        }


        //打开修改弹出层
        function openupdateNoticeLayer(data) {
            //console.log(data);
            mainIndex = layer.open({
                type:1,
                content:$("#addOrUpdateDiv"),
                area:['700px','500px'],
                title:'修改公告',
                success:function () {
                    $("#dataFrm")[0].reset();    //表单重置
                    //装载新的数据
                    form.val("dataFrm",data);
                    layedit.setContent(editIndex,data.content);    //把textarea编辑器中的内容装载到富文本中
                    url="/notice/updateNotice";
                }
            });
        };

        //批量删除
        function batchDelete() {
            //得到选中行
            var checkStatus = table.checkStatus('noticeTable');
            var dataLength = checkStatus.data.length;
            if (dataLength>0){
                layer.confirm('你确定要删除这些公告吗？',{icon: 3,title: '提示'},function (index) {
                    //获取选中行数据
                    var data = checkStatus.data;
                    var ids = "";
                    $.each(data,function (index, item) {
                        if (index==0){
                            ids+="ids="+item.id;
                        }else {
                            ids+="&ids="+item.id;
                        }
                    });
                    $.post("/notice/batchDeletenotice",ids,function (res) {
                        if (res.code==200){
                            //重新刷新表格
                            tableIns.reload({
                                where:"",
                            });
                        }
                        layer.msg(res.msg);
                    });
                    layer.close(index);
                });
            }else {
                layer.msg("请选中操作行")
            }
        }



    });
</script>
</body>
</html>